查看原文
其他

UI专项-元素定位方式和思考

转转QA 转转QA 2022-11-09

作者:邹德龙

编稿:庄锦弟

前言:

要做好UI自动化测试,做好元素定位很重要,也经常收到反馈说定位难,但是有些东西是可以提炼出来共同点的。接下来简单看看android和ios可以分别怎么定位,以及实践UI自动化以来提炼的思想:

一、Android定位

前置: adb命令、python3、可开启开发者选项的安卓手机

工具: WEditor(支持windows/Mac双平台)

安装: 安装weditor,在终端中输入

pip install weditor


元素定位开始:

1、手机连接安卓设备(安卓设备得开启USB调试),部分手机得启用视图属性检查功能。

2、通过adb devices获取到机器的设备号

3、启动weditor,执行

python -m weditor


4、启动成功后页面

1)选择android

2)输入adb devices获取的设备号

3)点击connect按钮可链接设备,这时候设备会弹出软件安装申请,选择安装选项

5、打开想要抓取元素的APP的页面,点击 Dump Hierarchy按钮刷新页面,抓取页面元素,若想切换别的页面抓取,操作APP后点击刷新按钮即可。

报错解决:

1、如果启动报错:atx-agent recover failed

pip install --upgrade --pre uiautomator2  

二、IOS定位

前置: python3、装有WDA的Iphone手机

工具: tidevice 、appium 1.21.0

安装:

1、安装tidevice,在终端中输入

pip install tidevice

2、appium 官网下载安装即可(装最新版本)

元素定位开始:

1、tidevice applist 查看安装应用程序同时查看设备上的第三方应用包名,若提示信任弹窗,点击信任

2、连接iOS设备,查看连接设备命令,查看设备UDID:

tidevice list 

采坑点:可能碰到驱动问题点电脑无法正常连接手机设备,可下载爱思助手工具自动修复驱动

3、启动WDA

tidevice -u 设备UDID wdaproxy -B WDA包名 -p 8200

设备UDID :注意替换为自己设备UDID(例如:0000xxxxxxx ) WDA包名:替换wda为自己的包名(例如:xxxx.xctrunner) 启动成功:

4、打开appium,注意为1.20.2版本及以上,启动服务器

5、开始元素定位

1)打开appium启动服务,点击File - New Session Windows - 输入JSON Reoresentation 参数 - 启动会话

JSON Reoresentation 示例:

{
    "deviceName""xxxx",     # 通用 - 关于手机 - 名称
    "bundleId""xxxxx",    # 应用包名
    "platformversion""14.4",    # 手机版本
    "udid""000080xxxxxxxxxxxE",    # UDID
    "webDriverAgentUrl""http://localhost:8200",
    "platformName""IOS",
    "xcodeOrgId""xxxxxx",   # xcodeOrgId
    "automationName""XCUITest",
    "usePrebuiltWDA"true,
    "useXctestrunFile"false,
    "skipLogCapture"true
}

2)启动成功后即可开始抓取元素

三、提炼思想

大道至简:用简单好用高效的元素定位:

Android :id > text > img > ocr > xpath

IOS : name > text > img > ocr > xpath

Web/H5:name > id > text > selector

网络延迟:finds 框架方法(查找元素设置超时时间,间隔性扫描元素若元素存在则执行下一步,若超过指定时长未查找到元素则为失败,推荐使用),element_is_existed 框架方法(设置元素最长寻找时间,找到元素则返回True ,未找到元素则返回False

模糊匹配:不要在一棵树上吊死,模糊匹配,不同版本中text元素(例如原价、秒杀价等)可能只有部分文案变化部分文案固定不变,可用模糊匹配命中。

总结:

  • 元素定位是UI自动化的基础能力,先有元素后有操作。
  • 元素定位方式的选择决定了Case的执行效率和稳定性, 也决定了哪些功能可以通过UI自动化实现覆盖。
  • WEditor、Appium inspector 等只是获取定位方式的工具。
  • 如果你想要做好元素定位,推荐大家多多学习各种控件的特性、实现方式 和 页面布局思想~

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存